package com.lxp.project.system.domain;

import com.lxp.common.core.domain.BaseEntity;
import com.mybatisflex.annotation.*;
import jakarta.validation.constraints.Email;
import jakarta.validation.constraints.NotBlank;
import jakarta.validation.constraints.NotNull;
import jakarta.validation.constraints.Size;
import lombok.Data;
import lombok.EqualsAndHashCode;

import java.io.Serial;
import java.util.ArrayList;
import java.util.List;

/**
 * 部门表 sys_dept
 *
 * @author lxp
 */
@EqualsAndHashCode(callSuper = true)
@Data
@Table(value = "sys_dept")
public class SysDept extends BaseEntity {
    @Serial
    private static final long serialVersionUID = 1L;

    /**
     * 部门ID
     */
    @Id(keyType = KeyType.Auto)
    private Long deptId;

    /**
     * 父部门ID
     */
    private Long parentId;

    /**
     * 祖级列表
     */
    private String ancestors;

    /**
     * 部门名称
     */
    @NotBlank(message = "部门名称不能为空")
    @Size(max = 30, message = "部门名称长度不能超过30个字符")
    private String deptName;

    /**
     * 显示顺序
     */
    @NotNull(message = "显示顺序不能为空")
    private Integer orderNum;

    /**
     * 负责人
     */
    private String leader;

    /**
     * 联系电话
     */
    @Size(max = 11, message = "联系电话长度不能超过11个字符")
    private String phone;

    /**
     * 邮箱
     */
    @Email(message = "邮箱格式不正确")
    @Size(max = 50, message = "邮箱长度不能超过50个字符")
    private String email;

    /**
     * 部门状态:0正常,1停用
     */
    private String status;

    /**
     * 删除标志（0代表存在 2代表删除）
     */
    private String delFlag;

    /**
     * 父部门名称
     */
    @Column(ignore = true)
    @RelationManyToOne(selfField = "parentId", targetTable = "sys_dept", targetField = "deptId", valueField = "deptName")
    private String parentName;

    /**
     * 子部门
     */
    @Column(ignore = true)
    @RelationOneToMany(selfField = "deptId", targetField = "parentId")
    private List<SysDept> children = new ArrayList<>();

}
